package com.huike.report.mapper;

import java.util.List;

import com.huike.report.domain.vo.PieChartVO;
import org.apache.ibatis.annotations.Param;

/**
 * 首页统计分析的Mapper
 *
 * @author Administrator
 */
public interface ReportMapper {
    /**=========================================基本数据========================================*/
    /**
     * 获取线索数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 线索数量
     */
    Integer getCluesNum(@Param("startTime") String beginCreateTime,
                        @Param("endTime") String endCreateTime,
                        @Param("username") String username);

    /**
     * 获取商机数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 商机数量
     */
    Integer getBusinessNum(@Param("startTime") String beginCreateTime,
                           @Param("endTime") String endCreateTime,
                           @Param("username") String username);

    /**
     * 获取合同数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 合同数量
     */
    Integer getContractNum(@Param("startTime") String beginCreateTime,
                           @Param("endTime") String endCreateTime,
                           @Param("username") String username);

    /**
     * 获取合同金额
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 合同金额
     */
    Double getSalesAmount(@Param("startTime") String beginCreateTime,
                          @Param("endTime") String endCreateTime,
                          @Param("username") String username);

    /**
     * =========================================今日简报========================================
     */

    /**
     * 获取线索数量
     *
     * @param username 用户名
     * @return 线索数量
     */
    Integer getCluesNumber(@Param("username") String username);

    /**
     * 获取商机数量
     *
     * @param username 用户名
     * @return 商机数量
     */
    Integer getBusinessNumber(@Param("username") String username);

    /**
     * 获取合同数量
     *
     * @param username 用户名
     * @return 合同数量
     */
    Integer getContractNumber(@Param("username") String username);

    /**
     * 获取合同金额
     *
     * @param username 用户名
     * @return 合同金额
     */
    Double getSalesAll(@Param("username") String username);

    /**=========================================待办========================================*/

    /**
     * 首页--今日待办--待分配线索数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 待分配线索数目
     */
    Integer toAllocatedCluesNum(@Param("startTime") String beginCreateTime,
                                @Param("endTime") String endCreateTime,
                                @Param("username") String username);

    /**
     * 首页--今日待办--待分配商机数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 待分配商机数目
     */
    Integer toAllocatedBusinessNum(@Param("startTime") String beginCreateTime,
                                   @Param("endTime") String endCreateTime,
                                   @Param("username") String username);

    /**
     * 首页--今日待办--待跟进线索数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 待跟进线索数目
     */
    Integer toFollowedCluesNum(@Param("startTime") String beginCreateTime,
                               @Param("endTime") String endCreateTime,
                               @Param("username") String username);

    /**
     * 首页--今日待办--待跟进商机数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @param username        用户名
     * @return 待跟进商机数目
     */
    Integer toFollowedBusinessNum(@Param("startTime") String beginCreateTime,
                                  @Param("endTime") String endCreateTime,
                                  @Param("username") String username);

    /**==========================================================================================*/

    /**
     * 统计分析-客户统计-学科客户分布饼图
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @return List<PieChartVO>
     */
    List<PieChartVO> getPieChart(@Param("startTime") String beginCreateTime,
                                 @Param("endTime") String endCreateTime);

    /**=================================统计分析--线索统计--线索转化率漏斗图================================*/

    /**
     * 查询时间范围内的线索数
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @return 时间范围内的线索数
     */
    Integer getAllClues(@Param("startTime") String beginCreateTime,
                        @Param("endTime") String endCreateTime);

    /**
     * 查询时间范围内的有效线索数
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @return 时间范围内的有效线索数
     */
    Integer getEffectiveCluesNums(@Param("startTime") String beginCreateTime,
                          @Param("endTime") String endCreateTime);

    /**
     * 查询线索转成商机的数目
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @return 线索转成商机的数目
     */
    Integer getBecomeBusiness(@Param("startTime") String beginCreateTime,
                              @Param("endTime") String endCreateTime);

    /**
     * 查询转换成合同的数量
     *
     * @param beginCreateTime 开始时间
     * @param endCreateTime   结束时间
     * @return 转换成合同的数量
     */
    Integer getBecomeContract(@Param("startTime") String beginCreateTime,
                              @Param("endTime") String endCreateTime);

    /**=================================首页--线索、商机转化龙虎榜接口================================*/


}
